/*
 * @author: Victor
 * @Date: 2021-11-28 17:36:18
 * @LastEditTime: 2021-11-28 19:52:44
 */
// 1.1 获取裁剪区域的 DOM 元素
var $image = $('#image');
// 1.2 配置选项
const options = {
  // 纵横比
  aspectRatio: 1,
  // 指定预览区域
  preview: '.img-preview',
};

// 1.3 创建裁剪区域
$image.cropper(options);
$('#btnChooseImage').on('click', function () {
  $('#file').click();
});

// 为文件选择框绑定 change 事件
$('#file').on('change', function (e) {
  // 获取用户选择的文件
  var filelist = e.target.files;
  if (filelist.length === 0) {
    return layer.msg('请选择照片！');
  }
  // 1. 拿到用户选择的文件
  var file = e.target.files[0];
  // 2. 将文件，转化为路径
  var imgURL = URL.createObjectURL(file);
  // console.log(imgURL); // 得到一个指向图片数据的字符串
  // 3. 重新初始化裁剪区域
  $image
    .cropper('destroy') // 销毁旧的裁剪区域
    .attr('src', imgURL) // 重新设置图片路径
    .cropper(options); // 重新初始化裁剪区域
});

$('#upload').click(function () {
  var dataURL = $image
    .cropper('getCroppedCanvas', {
      // 创建一个 Canvas 画布
      width: 100,
      height: 100,
    })
    .toDataURL('image/png');
  //   console.log(dataURL, typeof dataURL);
  // 请求接口 上传文件(base64字符串)
  $.ajax({
    method: 'POST',
    url: '/my/update/avatar',
    data: {
      avatar: dataURL,
    },
    success: function (res) {
      if (res.status !== 0) {
        return layer.msg('更换头像失败！');
      }
      layer.msg('更换头像成功！');
      window.parent.getUserInfo();
    },
  });
});
